<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <!-- 引入样式 -->
  <link rel="stylesheet" href="../../plugins/element-ui/index.css" />
  <link rel="stylesheet" href="../../styles/common.css" />
  <link rel="stylesheet" href="../../styles/page.css" />
  <style>
    #member-app  .notAdmin::after{
      border: 0 !important;

    }
  </style>
</head>
<body>
  <div class="dashboard-container" id="member-app">
    <div class="container">
      <div class="tableBar">
        <el-input
          v-model="input"
          placeholder="请输入员工姓名"
          style="width: 250px"
          clearable
           @keyup.enter.native="handleQuery"
        >
          <i
            slot="prefix"
            class="el-input__icon el-icon-search"
            style="cursor: pointer"
            @click="handleQuery"
          ></i>
        </el-input>
        <el-button
          type="primary"
          @click="addMemberHandle('add')"
        >
          + 添加员工
        </el-button>
      </div>
      <el-table
        :data="tableData"
        stripe
        class="tableBox">
        <el-table-column
          prop="name"
          label="员工姓名"
        ></el-table-column>
        <el-table-column
          prop="username"
          label="账号"
        ></el-table-column>
        <el-table-column
          prop="phone"
          label="手机号"
        ></el-table-column>
        <el-table-column label="账号状态">
          <template slot-scope="scope">
            {{ String(scope.row.status) === '0' ? '已禁用' : '正常' }}
          </template>
        </el-table-column>
        <el-table-column
          label="操作"
          width="160"
          align="center"
        >
          <template slot-scope="scope">
            <el-button
              type="text"
              size="small"
              class="blueBug"
              @click="addMemberHandle(scope.row)"
              :class="{notAdmin:user !== 'admin'}">
              编辑
            </el-button>
            <el-button
              type="text"
              size="small"
              class="delBut non"
              @click="statusHandle(scope.row)"
              v-if="user === 'admin'">
              {{ scope.row.status == '1' ? '禁用' : '启用' }}
            </el-button>
          </template>
        </el-table-column>
      </el-table>
      <el-pagination
        class="pageList"
        :page-sizes="[5, 10, 15, 20]"
        :page-size="pageSize"
        layout="total, sizes, prev, pager, next, jumper"
        :total="counts"
        :current-page.sync="page"
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
      ></el-pagination>
    </div>
  </div>
    <!-- 开发环境版本，包含了有帮助的命令行警告 -->
    <script src="../../plugins/vue/vue.js"></script>
    <!-- 引入组件库 -->
    <script src="../../plugins/element-ui/index.js"></script>
    <!-- 引入axios -->
    <script src="../../plugins/axios/axios.min.js"></script>
    <script src="../../js/request.js"></script>
    <script src="../../api/member.js"></script>
    <script>
      new Vue({
        el: '#member-app',
        data() {
          return {
             input: '',
             counts: 0,
             page: 1,
             pageSize: 5,
             tableData : [],
             id : '',
             status : '',
          }
        },
        computed: {},
        created() {

          //初始化数据
          this.init()

          //获取当前登录用户的用户名！
          this.user = JSON.parse(localStorage.getItem('userInfo')).username
        },
        mounted() {
        },
        methods: {
          async init () {

            //准备参数
            const a = {
              page: this.page, // 页码数
              pageSize: this.pageSize, //每页显示条数
              name: this.input ? this.input : undefined //输入框的搜索的内容
            }

         /*   var url = "/employee/page?page="+params.page+"&pageSize="+params.pageSize;
            if(params.name){
              url  = url +"&name="+params.name;
            }*/


            /*
              发请求
                1. 员工的分页参数，有2个是固定的： page 和 pageSize , 有一个是不固定的： name ， 可有可无
                2. get请求携带数据的时候都是拼接到地址栏上，我们可有自主的判定是否有值，有值，就追加条件。
                   var url = "/employee/page?page="+params.page+"&pageSize="+params.pageSize;
                  if(params.name){
                    url  = url +"&name="+params.name;
                  }
                3. 但是这种写法不高明，要想到以后如果页面上有5个输入框允许输入搜索的条件，甚至是50个输入框...
                  那么if就要写很多了。
                4. axios 的 get 请求，也允许在参数位置放JS对象，它会自动的把JS对象里面的非空， 非undefined 的数据拼接到地址上。
                  4.1 这种规则有一个要求，就是必须使用一个更大的JS对象来包装这份要传递的JS 对象。
                  4.2 然后包装的属性名必须叫做： params, 形如：
                    axios.get("请求地址" , {params:本身要传递的JS 对象});

             */
            axios.get( "/employee/page" , {params:a}).then(resp=>{
              console.log("分页结果：");
              console.log(resp);
              this.tableData = resp.data.data.records;
              this.counts = resp.data.data.total;
            })

            /*await getMemberList(params).then(res => {
              if (String(res.code) === '1') {
                this.tableData = res.data.records || []
                this.counts = res.data.total
              }
            }).catch(err => {
              this.$message.error('请求出错了：' + err)
            })*/



          },
          handleQuery() {
            this.page = 1;
            this.init();
          },
           // 添加
          addMemberHandle (st) {
            if (st === 'add'){

              //1. 把更新保存的数据线清空了。
              sessionStorage.removeItem("employee");

              //2. 再跳转页面
              window.parent.menuHandle({
                id: '2',
                url: '/backend/page/member/add.html',
                name: '添加员工'
              },true)
            } else {

              //1. 先把当前这一条目绑定的对象存储起来
              sessionStorage.setItem("employee" , JSON.stringify(st))

              //2. 跳转到隔壁的更新页面
              window.parent.menuHandle({
                id: '2',
                url: '/backend/page/member/add.html',
                name: '修改员工'
              },true)
            }
          },
          //状态修改
          statusHandle (row) {
            this.id = row.id
            this.status = row.status
            this.$confirm('确认调整该账号的状态?', '提示', {
              'confirmButtonText': '确定',
              'cancelButtonText': '取消',
              'type': 'warning'
              }).then(() => {
              enableOrDisableEmployee({ 'id': this.id, 'status': !this.status ? 1 : 0 }).then(res => {
                console.log('enableOrDisableEmployee',res)
                if (String(res.code) === '1') {
                  this.$message.success('账号状态更改成功！')
                  this.handleQuery()
                }
              }).catch(err => {
                this.$message.error('请求出错了：' + err)
              })
            })
          },
          handleSizeChange (val) {
            this.pageSize = val
            this.init()
          },
          handleCurrentChange (val) {
            this.page = val
            this.init()
          }
        }
      })
    </script>
</body>
</html>